#### Computer Organization & Design实验与课程设计

# Lab01-1 ALU、Regfiles设计

Ma De (马德)

made@zju.edu.cn

2020

College of Computer Science, Zhejiang University

#### **Course Outline**

- 一、实验目的
- 二、实验环境
- 三、实验目标及任务

# 实验目的

- 1. 复习寄存器传输控制技术
- 2. 掌握CPU的核心组成:数据通路与控制器
- 3. 设计数据通路的功能部件
- 4. 进一步了解计算机系统的基本结构
- 5. 熟练掌握IP核的使用方法

# 实验环境

- □实验设备
  - 1. 计算机(Intel Core i5以上,4GB内存以上)系统
  - 2. Spartan-3 Starter Kit Board/Sword开发板
  - 3. Xilinx VIVADO2017.4及以上开发工具
- □材料

无

# 实验目标及任务

■ 目标:熟悉SOC系统的原理,掌握IP核集成设计 CPU的方法,了解数据通路结构并实现ALU和 Register Files

■任务一:设计实现数据通路部件ALU

---采用原理图的设计方法

■任务二:设计实现数据通路部件Register Files

---采用硬件描述语言的设计方法

■任务一:设计实现数据通路部件ALU

---采用原理图的设计方法

本实验做到时序仿真,后续实验将调用,必须保证其正确

# 数据通路的功能部件之一: ALU

#### □ 实现5个基本运算

- ■整理逻辑实验八的ALU
- ■逻辑图输入并仿真

| ALU Control Lines | Function         | note |
|-------------------|------------------|------|
| 000               | And              | 兼容   |
| 001               | Or               | 兼容   |
| 010               | Add              | 兼容   |
| 110               | Sub              | 兼容   |
| 111               | Set on less than |      |
| 100               | nor              | 扩展   |
| 101               | srl              | 扩展   |
| 011               | xor              | 扩展   |







#### 拷贝下列模块到ALU工程目录:

(Exp00提供)

and32、or32、ADC32、xor32、nor32、srl32、 SignalExt\_32、mux8to1\_32、or\_bit\_32

#### 添加模块路径到ALU工程

# 或

#### 建议将自己封装的核复制到ORGIP子目录统一加载:











```
ALU wrapper ALU wrapper u(
       . A(A),
       . B(B),
       . ALU_operation(ALU_operation),
       .res(res),
       .zero(zero)
  initial begin
       A=32' hA5A5A5A5:
       B=32' h5A5A5A5A:
       ALU_operation =3' b111;
       #100:
       ALU operation =3' b110;
       #100:
       ALU operation =3' b101;
       #100:
       ALU operation =3' b100;
       #100:
       ALU operation =3' b011;
       #100;
       ALU operation =3' b010;
       #100:
       ALU operation =3' b001;
       #100:
       ALU_operation =3' b000;
       #100;
       A=32' h01234567:
       B=32' h76543210:
       ALU_operation =3' b111;
   end
endmodule
```







仿真通过后封装逻辑符号

```
✓ ♣ ■ ALU (ALU.bd) (15)

    ₽ ALU_MUX8T1_32_0_0 (ALU_MUX8T1_32_0_0.xci)
    ♣ ALU_SignalExt_32_0_0 (ALU_SignalExt_32_0_0.xci)
    ♣ ALU_addc_32_0_0 (ALU_addc_32_0_0.xci)
    ♣ ALU_and32_0_0 (ALU_and32_0_0.xci)
    ♣ ALU_nor32_0_0 (ALU_nor32_0_0.xci)
    ♣ ALU_or32_0_0 (ALU_or32_0_0.xci)
    ♣ ALU_or_bit_32_0_0 (ALU_or_bit_32_0_0.xci)
    ♣ ALU_srl32_0_0 (ALU_srl32_0_0.xci)
    ♣ ALU_xlconcat_0_0 (ALU_xlconcat_0_0.xci)
    P ALU_xlconstant_0_0 (ALU_xlconstant_0_0.xci)
    Table ALU_xislice_0_0 (ALU_xislice_0_0.xci)
    ♣ ALU_xIslice_1_0 (ALU_xIslice_1_0.xci)
    Table 2 O (ALU_xislice_2_0.xci)
    ₽ ALU_xor32_0_0 (ALU_xor32_0_0.xci)
    ₽ ALU_xor32_0_1 (ALU_xor32_0_1.xci)
```

ALU模块调用结构

■任务二:设计实现数据通路部件Register Files

---采用硬件描述语言的设计方法

本实验做到时序仿真,后续实验将调用,必须保证其正确

#### 数字系统的功能部件之一: Register files

- □实现32×32bit寄存器组
  - ■优化逻辑实验Regs
  - 行为描述并仿真结果
- □端口要求
  - 二个读端口:
    - □ Rs1\_addr
    - ■Rs2 addr
  - 一个写端口,带写信号
    - Wt\_addr
    - □ RegWrite



### Regfile参考代码

```
clk
Module regs(input
                             clk, rst, RegWrite,
                                                                rst
              input [4:0] Rs1_addr, Rs2_addr, Wt_addr,
                                                                ■Rs1 addr[4:0]
                                                                                  Rs1_data[31:0]
              input [31:0] Wt data,
                                                                Rs2_addr[4:0]
                                                                                  Rs2 data[31:0]
              output [31:0] Rs1 data, Rs2 data
                                                                ■Wt addr[4:0]
                                                                Wt data[31:0]
                                                                RegWrite
                                        // r1 - r31
reg [31:0] register [1:31];
                                                                          Regs v1 0
  integer i;
                                                                      仿真通过后封装逻辑符号
   assign rdata_A = (Rs1_addr== 0) ? 0 : register[Rs1_addr];
                                                                                 // read
                                                                                // read
   assign rdata B = (Rs2 addr== 0) ? 0 : register[Rs2 addr];
   always @(posedge clk or posedge rst)
     begin if (rst==1) for (i=1; i<32; i=i+1) register[i] <= 0;
                                                                                 // reset
            else if ((Wt addr != 0) && (RegWrite == 1))
                     register[Wt addr] <= Wt data;</pre>
                                                                                 // write
     end
endmodule
```

Regs

#### regfile仿真结果

```
Ons-100ns regfile初始化复位,读写都为0;
```

```
100ns-150ns RegWrite=1;Wt_addr[4:0]=05;Wt_data[31:0]=a5a5a5a5;写地址05 150ns-200ns RegWrite=1;Wt_addr[4:0]=0a;Wt_data[31:0]=5a5a5a5a5;写地址0a 200ns-300ns RegWrite=0;Rs1_addr[4:0]=05;Rs1_data[31:0]=a5a5a5a5a5;读地址05 200ns-300ns RegWrite=0;Rs2_addr[4:0]=0a;Rs1_data[31:0]=5a5a5a5a5a;读地址0a
```



仿真正确之后,封装为IP

### Regfile對裝失键点

□ 寄存器堆带有clk和rst; 直接封装时会存在两个问题

IP will be made available in the catalog using the repository -

Edit packaging settings

■端口警告

Review and Package



c:/Users/ASUS/Desktop/OExp\_RISCV/OExp04/OExp04-DataPath/CPU/OExp04-PC\_REG32/OExp04-PC\_REG32.srcs/sources\_1/new

Re-Package IP

### Regfile對裝失键点

- □ 寄存器堆带有clk和rst; 直接封装时会存在两个问题
  - ■端口警告原因是clk端口属性未知
  - 复位信号自动反向原因是系统默 认是低电平而实验设计时高电平 ,需要进行属性约束





### Regfile對裝失键点---clk

点击clk进入端口编辑界面,Parameters下添加



### Regfile對装关键点——clk

□ 然后在新建的ASSOCIATED\_BUSIF这个参数后面的value 列输入定义的时钟信号的名字,此处为clk



#### Regfile 對装关键点——rst

□ 点击rst进入端口编辑界面,Parameters下添加POLARITY



#### Regfile 對装关键点---rst

□ 然后在新建的POLARITY这个参数后面的value列输入属性ACTIVE\_HIGH



□ 注意: 后续封装的含时钟和复位信号的IP, 建议均作此类 属性限制以免设计时产生问题

## 思考题

- □如何结ALU增加溢出功能
  - ■提示:分析运算结果的符号
- □分析逻辑Exp10的Register Files设计
  - ■本实验你做了那些优化?
  - ■逻辑Exp10的Register Files直接使用,你认为会存在那些问题?

